<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>02_外间距测试</title>
    <style>
        /* 去掉body元素自带的四个方向的外间距 */
        body{
            margin: 0;
        }
        /* 去掉所有元素自带的所有内外间距 */
        *{
            margin: 0;
            padding: 0;
        }
        .fu{
            background-color: rgba(255,255,0,.5);
            /* 2.父子粘连/贴边:
            现象：首个子元素的上外间距与最后一个子元素的下外间距会超出父元素的范围
            解决:给父元素加形成BFC结界保护 */
            overflow: hidden; /* 形成了BFC结界*/
        }
        .fu>div{
            width: 100px;  /* 设置元素宽度 */
            height: 100px; /* 设置元素高度 */
            background-color: rgba(0,0,255,.21); /* 设置元素背景色,带透明度*/
            border: 3px solid #000; /* 设置元素边框 */
            color: #fff; /* 设置元素文字颜色 */
            font-size: 25px; /* 设置字号 */
            font-weight: bold; /* 设置文字子重,加粗  */
        }
        /* 1.相邻兄弟在垂直方向的外间距取大值显示,并不会累加*/
        .z1{
            margin-bottom: 30px;
            margin-top: 50px;
        }
        .z2{
            margin-top: 50px;
        }
        .z3{
            margin: 10px; /* 四个方向的外间距都是10px */
            margin: 10px 20px; /* 上下10px 左右20px */
            margin: 10px 20px 30px; /* 上10px 左右20px 下30px */
            margin: 10px 20px 30px 40px; /* 上右下左 顺时针依次赋值*/
            /* 实现块级元素自身的水平居中 auto会自动将元素的左右外间距计算成相等的值 */
            margin: 0 auto;
        }
        .z4{
            margin-bottom: 30px;
        }
        span {
            border: 2px solid #5F6;
        }
        .s2{
            /* 3.行内元素垂直方向上的外间距不生效! */
            margin: 30px;
        }
    </style>
</head>
<body>
    <span>span1</span><span class="s2">span2</span><span>span3</span>
    <!-- .fu>.z*4 -->
    <div class="fu">
        <div class="z1">子元素1</div>
        <div class="z2">子元素2</div>
        <div class="z3">子元素3</div>
        <div class="z4">子元素4</div>
    </div>
</body>
</html>